Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add support for containerd v3 configs #805

Merged
merged 3 commits into from
Jan 15, 2025

Conversation

alam0rt
Copy link
Contributor

@alam0rt alam0rt commented Nov 18, 2024

With the release of containerd 2.0 comes a new default config version. This PR attempts to support the new version 3 of the containerd configuration.

Version 3 is fairly similar to 2 and for all intents and purposes, a valid version 3 config is a valid version 2 config (bar the version of course). So for now I've just gone and copied the V2 logic and changed things here and there.

@alam0rt alam0rt force-pushed the add-v3-containerd-config branch from 91269ac to 96934b2 Compare November 18, 2024 06:00
)

// ConfigV3 represents a version 3 containerd config
type ConfigV3 Config
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If the v3 config is the same as the v2 config then we should not duplicate the logic for the functions here.

Are there any differences that are relevant to the runtime sections?

@@ -89,14 +91,16 @@ func New(opts ...Option) (engine.Interface, error) {
return (*ConfigV1)(cfg), nil
case 2:
return cfg, nil
case 3:
return (*ConfigV3)(cfg), nil
}

return nil, fmt.Errorf("unsupported config version: %v", version)
}

// parseVersion returns the version of the config
func (c *Config) parseVersion(useLegacyConfig bool) (int, error) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We've essentially replaced the useLegacyConfig variable with the configVersion option. Would it make sense to update the implementation here to something like:

defaultVersion := 3
if c.configVersion != 0 {
    defaultVersion = c.configVersion
}

and drop the useLegacyConfig argument?

@@ -30,7 +30,7 @@ type builder struct {
configSource toml.Loader
path string
runtimeType string
useLegacyConfig bool
configVersion int64
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is technically the defaultVersion since the version in the config file overwrites this.

@elezar elezar force-pushed the add-v3-containerd-config branch from 96934b2 to c11d433 Compare November 29, 2024 14:41
@elezar elezar changed the title Work in progress: Add v3 containerd config Add support for containerd v3 configs Nov 29, 2024
@elezar
Copy link
Member

elezar commented Nov 29, 2024

@alam0rt I have taken these changes and reworked them. I hope you don't have an issue with me rebasing your commits to get them a little more streamlined. Let me know what you think.

@elezar elezar self-assigned this Nov 29, 2024
@elezar
Copy link
Member

elezar commented Nov 29, 2024

@cdesiniotis @tariq1890 this is something that will be required for the next GPU Operator release and we could consider backporting this too.

@elezar elezar marked this pull request as ready for review November 29, 2024 14:45
@elezar elezar force-pushed the add-v3-containerd-config branch from c11d433 to 5d073fb Compare November 29, 2024 16:13
@alam0rt
Copy link
Contributor Author

alam0rt commented Nov 29, 2024

@alam0rt I have taken these changes and reworked them. I hope you don't have an issue with me rebasing your commits to get them a little more streamlined. Let me know what you think.

I absolutely do not mind. Thanks for taking a look! Have been a bit inundated so I haven't had a chance to rework it myself

@cdesiniotis
Copy link
Contributor

It looks like io.containerd.grpc.v1.cri was renamed to io.containerd.cri.v1.runtime in the v3 configuration file. I was able to get things to work with this commit: cdesiniotis@16b5376.

@cdesiniotis
Copy link
Contributor

@alam0rt I have gone ahead and updated this PR with my commit.

@elezar @tariq1890 please take a look.

@cdesiniotis cdesiniotis requested a review from elezar December 19, 2024 06:21
config.SetPath([]string{"plugins", "cri", "containerd", "default_runtime", "runtime_engine"}, "")
config.SetPath([]string{"plugins", "cri", "containerd", "default_runtime", "privileged_without_host_devices"}, false)
if setAsDefault {
if !c.UseLegacyConfig {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Can we invert the if-else block here? It would look more readable if we avoid the NOT statement when possible

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

inverted it

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@tariq1890 I kept the ordering of the blocks the same to reduce the diff against main. @alam0rt this means that I reverted your commit that inverts the block (which was not signed-off in any case).

RemoveRuntime(string) error
Save(string) (int64, error)
GetRuntimeConfig(string) (RuntimeConfig, error)
Set(string, interface{})
String() string
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see that we are only using this in unit tests, do we really need to add a new interface method for this?

Copy link
Member

@elezar elezar Jan 15, 2025

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry @tariq1890, I missed this. I will have a look again and see if we can clean up the interface as a follow-up.

The issue is that the New function that we call in tests returns an interface type and adding a String() function was simpler than adding type casts. Let me see what the latter looks like.

case 1:
return (*ConfigV1)(cfg), nil
case 2:
cfg.CRIRuntimePluginName = "io.containerd.grpc.v1.cri"
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The intent of this switch statement is just to cast the config to the correct type, so instead of doing this here, should we set some local based on the version above and set CRIRuntimePluginName in the instantiation directly?

I think we could add b.criRuntimePluginName(version) or something to make this cleaner.

type builder struct {
logger logger.Interface
configSource toml.Loader
configVersion int
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Did we want to allow the CRIRuntimePluginName to be overridden?

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I didn't update this to allow it to be overridden. If we see this as a requirement, plumbing a value through should be relatively straightforward.

@elezar elezar force-pushed the add-v3-containerd-config branch from e6f8211 to c75b67c Compare January 14, 2025 09:45
@elezar elezar requested review from elezar and tariq1890 January 14, 2025 13:48
@elezar elezar added the must-backport The changes in PR need to be backported to at least one stable release branch. label Jan 14, 2025
This change adds support for containerd configs with version=3.
From the perspective of the runtime configuration the contents of the
config are the same. This means that we just have to load the new
version and ensure that this is propagated to the generated config.

Note that v3 config also requires a switch to the 'io.containerd.cri.v1.runtime'
CRI runtime plugin. See:
https://github.com/containerd/containerd/blob/v2.0.0/docs/PLUGINS.md
containerd/containerd#10132

Note that we still use a default config of version=2 since we need to
ensure compatibility with older containerd versions (1.6.x and 1.7.x).

Signed-off-by: Sam Lockart <[email protected]>
Signed-off-by: Evan Lezar <[email protected]>
Signed-off-by: Christopher Desiniotis <[email protected]>
@elezar elezar force-pushed the add-v3-containerd-config branch from c75b67c to 95bda3a Compare January 15, 2025 09:33
@elezar elezar merged commit 11acbe7 into NVIDIA:main Jan 15, 2025
10 checks passed
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
must-backport The changes in PR need to be backported to at least one stable release branch.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants